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This listing of claims will replace all prior versions, and listings, of claims in the application. 
Listing of Claims: 

Claim 1 (Currently Amended): A storage platform comprising: 

a data store in which data stored therein is defined in terms of items, elements, and 
relationships, wherein an item is a unit of data storable in the data store and comprises one or 
more elements, an element is an instance of a type comprising one or more fields, and a 
relationship is a link between at least two items; 

a set of schemas that define different types of items, elements, and relationships; 

a customizable subset of schemas that extend the set of schemas and are dependent on 
the set of schemas; 

a synchronization service that synchronizes the storage platform with another storage 
platform and synchronizes the data store with data sources that implement proprietary 
protocols; and 

an application programming interface comprising a class for each of the different 
items, elements, and relationships defined in the set of schemas. 

Claim 2 (Original): The storage platform recited in claim 1, wherein data may also be stored 
in the data store in the form of an extension to an existing item type, and wherein the 
application programming interface comprises a class for each different item extension. 

Claim 3 (Original): The storage platform recited in claim 1, wherein the class for each type 
of item, element, and relationship is generated automatically based on the set of schemas that 
define each type of item, element, and relationship. 

Claim 4 (Original): The storage platform recited in claim 1, wherein the classes for each type 
of item, element, and relationship define a set of data classes, and wherein the application 
programming interface further comprises a second set of classes that define a common set of 
behaviors for the data classes. 
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Claim 5 (Original): The storage platform recited in claim 4, wherein the second set of classes 
comprise a first class that represents a storage platform scope and that provides the context 
for queries on the data store and a second class the represents the results of a query on the 
data store. 

Claim 6 (Original): The storage platform recited in claim 1, further comprising a database 
engine on which the data store is implemented, and wherein the different types of items, 
elements, and relationships in the data store are implemented in the database engine as user- 
defined types (UDT). 

Claim 7 (Original): The storage platform recited in claim 6, wherein the application 
programming interface provides a query model that enables application programmers to form 
queries based on various properties of the items in the data store, in a manner that insulates 
the application programmer from the details of the query language of the database engine. 

Claim 8 (Currently Amended): A method for providing an application programming 
interface between an application program and a storage platform for storing, organizing, 
sharing, and searching data, wherein the storage platform comprises a data store in which 
data stored therein is defined in terms of items, elements, and relationships, wherein an item 
is a unit of data storable in the data store and comprises one or more elements, an element is 
an instance of a type comprising one or more fields, and a relationship is a link between at 
least two items, said method comprising the steps of: 

providing a set of schemas that define different types of items, elements, and 
relationships; 

providing a customizable subset of schemas that extend the set of schemas and are 
dependent on the set of schemas; 

allowing synchronization of the storage platform with another storage platform and 
allowing the data store to be synchronized with data sources that implement proprietary 
protocols; and 

generating, as part of the application programming interface, a class for each of the 

different items, elements, and relationships defined in the set of schemas. 

Page 3 of 6 



DOCKET NO.: MSFT-2 733/305587.01 PATENT 
Application No.: 10/646,575 
Office Action Dated: June 14, 2005 

Claim 9 (Original): The method recited in claim 8, wherein data may also be stored in the 
data store in the form of an extension to an existing item type, and wherein the method 
further comprises generating a class for each different item extension. 

Claim 10 (Original): The method recited in claim 9, wherein the generated classes for each 
type of item, element, and relationship define a set of data classes, and wherein the method 
further comprises the step of providing, as an additional part of the application programming 
interface, a second set of classes that define a common set of behaviors for the data classes. 

Claim 1 1 (Original): The method recited in claim 10, wherein the second set of classes 
comprise a first class that represents a storage platform scope and that provides the context 
for queries on the data store and a second class the represents the results of a query on the 
data store. 

Claim 12 (Original): The method recited in claim 8, wherein the data store of the storage 
platform is implemented on a database engine, and wherein the method further comprises the 
step of implementing the different types of items, elements, and relationships in the data store 
as user-defined types (UDT) in the database engine. 

Claim 13 (Currently Amended): An application programming interface between an 
application program and a storage platform for storing, organizing, sharing, and searching 
data, wherein the storage platform comprises a data store in which data stored therein is 
defined in terms of items, elements, and relationships, wherein an item is a unit of data 
storable in the data store and comprises one or more elements, an element is an instance of a 
type comprising one or more fields, and a relationship is a link between at least two items, 
and wherein a set of schemas define different types of items, elements, and relationships, and 
a customizable subset of schemas extend the set of schemas and are dependent on the set of 
schemas, a synchronization service that synchronizes the storage platform with another 
storage platform and synchronizes the data store with data sources that implement proprietary 
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protocols, the application programming interface comprising a class for each of the different 
items, elements, and relationships defined in the set of schemas. 

Claim 14 (Original): The application programming interface recited in claim 13, wherein 
data may also be stored in the data store in the form of an extension to an existing item type, 
and wherein the application programming interface further comprises a class for each 
different item extension. 

Claim 15 (Original): The application programming interface recited in claim 13, wherein the 
classes for each type of item, element, and relationship define a set of data classes, and 
wherein the application programming interface further comprises a second set of classes that 
define a common set of behaviors for the data classes. 

Claim 16 (Original): The application programming interface recited in claim 15, wherein the 
second set of classes comprise a first class that represents a storage platform scope and that 
provides the context for queries on the data store and a second class the represents the results 
of a query on the data store. 
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